mssql

推荐列表 站点导航

当前位置:首页 > 数据库 > mssql >

关于sql server批量插入和更新的两种解决方案

来源:网络整理  作者:网络  发布时间:2020-12-12 13:34
对于sql 来说操作集合类型(一行一行)是比较麻烦的一件事,而一般业务逻辑复杂的系统或项目都会涉及到集合遍历的...
OPEN data_cursor
/*
BEGIN
END
DECLARE @Results NVARCHAR(MAX) SET @Results=''
DECLARE @Id INT
OPEN dataItem_cursor

WHILE @@FETCH_STATUS=0


*/
.While方式

(
END
*/
SELECT @Results
CLOSE dataItem_cursor

复制代码 代码如下:

在这里做逻辑处理,插入或更新操作 ...
INSERT INTO @Temp SELECT (SELECT * FROM split(@Data,';'))
BEGIN

CLOSE data_cursor
DECLARE @Temp TABLE
DECLARE @dataItem NVARCHAR(100)
SET @Data='1,tanw;2,keenboy' --Id,Name
DECLARE @Data NVARCHAR(max)
Name NVARCHAR(50)
Id INT IDENTITY(1,1),
FETCH NEXT FROM dataItem_cursor INTO @Id


SELECT TOP 1 @Id=Id,@Name=Name from @Temp

FETCH NEXT FROM dataItem_cursor INTO @Name
WHILE EXISTS(SELECT * FROM @Temp)
DELETE FROM @Temp where [id] = @Id
DEALLOCATE data_cursor
在这里做逻辑处理,插入或更新操作 ...
SET @Data='tanw,keenboy' --Id,Name

FETCH NEXT FROM data_cursor INTO @dataItem

DECLARE dataItem_cursor CURSOR FOR (SELECT * FROM split(@dataItem,','))

DECLARE @Name NVARCHAR(50)
)
DECLARE @Id INT

.游标方式 1 DECLARE @Data NVARCHAR(max)

复制代码 代码如下:

/*

如果是简单单表批量插入操作的,上面方法大可不必要


SET @Results=@Results+@Name+','
DECLARE data_cursor CURSOR FOR (SELECT * FROM split(@Data,';'))

DECLARE @Name NVARCHAR(50)
DEALLOCATE dataItem_cursor

相关热词: 解决

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mssql/2937.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

关于sql server批量插入和更新的两种解决方案

2020-12-12 编辑:网络

OPEN data_cursor
/*
BEGIN
END
DECLARE @Results NVARCHAR(MAX) SET @Results=''
DECLARE @Id INT
OPEN dataItem_cursor

WHILE @@FETCH_STATUS=0


*/
.While方式

(
END
*/
SELECT @Results
CLOSE dataItem_cursor

复制代码 代码如下:

在这里做逻辑处理,插入或更新操作 ...
INSERT INTO @Temp SELECT (SELECT * FROM split(@Data,';'))
BEGIN

CLOSE data_cursor
DECLARE @Temp TABLE
DECLARE @dataItem NVARCHAR(100)
SET @Data='1,tanw;2,keenboy' --Id,Name
DECLARE @Data NVARCHAR(max)
Name NVARCHAR(50)
Id INT IDENTITY(1,1),
FETCH NEXT FROM dataItem_cursor INTO @Id


SELECT TOP 1 @Id=Id,@Name=Name from @Temp

FETCH NEXT FROM dataItem_cursor INTO @Name
WHILE EXISTS(SELECT * FROM @Temp)
DELETE FROM @Temp where [id] = @Id
DEALLOCATE data_cursor
在这里做逻辑处理,插入或更新操作 ...
SET @Data='tanw,keenboy' --Id,Name

FETCH NEXT FROM data_cursor INTO @dataItem

DECLARE dataItem_cursor CURSOR FOR (SELECT * FROM split(@dataItem,','))

DECLARE @Name NVARCHAR(50)
)
DECLARE @Id INT

.游标方式 1 DECLARE @Data NVARCHAR(max)

复制代码 代码如下:

/*

如果是简单单表批量插入操作的,上面方法大可不必要


SET @Results=@Results+@Name+','
DECLARE data_cursor CURSOR FOR (SELECT * FROM split(@Data,';'))

DECLARE @Name NVARCHAR(50)
DEALLOCATE dataItem_cursor

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mssql/2937.shtml

相关文章

风云图片

推荐阅读

返回mssql频道首页